/* 主要实现用户管理子服务的服务器搭建 */

#include "user_server.hpp"

DEFINE_bool(run_mode, false, "程序的运行模式， false-调试； true-发布");
DEFINE_string(log_file, "", "发布模式下，用于指定日志的输出文件");
DEFINE_int32(log_level, 0, "发布模式下，用于指定日志输出等级");

DEFINE_string(registry_host, "127.0.0.1:2379", "服务注册中心地址");
DEFINE_string(base_service, "/service", "服务监控根目录");
DEFINE_string(instance_name, "/user_service/instance", "当前实例名称");
DEFINE_string(access_host, "127.0.0.1:10003", "当前实例的外部访问地址");
DEFINE_int32(listen_port, 10003, "Rpc服务器监听端口");
DEFINE_int32(idle_timeout, -1, "Rpc调用超时时间");
DEFINE_int32(rpc_threads, 1, "Rpc的IO线程数量");

DEFINE_string(file_service, "/service/file_service", "文件管理子服务名称");

DEFINE_string(es_host, "http://127.0.0.1:9200/", "ES搜索服务器URL");

//MySQL相关
DEFINE_string(mysql_host, "127.0.0.1", "MySQL服务器访问地址");
DEFINE_string(mysql_user, "root", "MySQL服务器访问用户名");
DEFINE_string(mysql_password, "zhi204071", "MySQL服务器访问密码");
DEFINE_string(mysql_db, "chatsystem", "MySQL默认库名称");
DEFINE_string(mysql_cset, "utf8", "MySQL客户端字符集");
DEFINE_int32(mysql_port, 0, "MySQL服务器访问端口");
DEFINE_int32(mysql_pool_count, 4, "MySQL连接池的最大的数量");

//Redis相关
DEFINE_string(redis_host, "127.0.0.1", "这是Redis服务器的IP地址, 格式: 127.0.0.1");
DEFINE_int32(redis_port, 6379, "这个是Redis服务器的端口, 格式： 6379");
DEFINE_int32(redis_db, 0, "Redis默认库的编号, 默认为0号");
DEFINE_bool(redis_keep_alive, true, "是否进行长连接保活");

//DMSClient相关
DEFINE_string(dms_key_id, "DLDJODHDODL", "短信平台密钥ID");
DEFINE_string(dms_key_secret, "DLDJLJDOIENDPPJ", "短信平台密钥");


int main(int argc, char* argv[])
{
    google::ParseCommandLineFlags(&argc, &argv, true);
    ChatSystem::InitLogger(FLAGS_run_mode, FLAGS_log_file, FLAGS_log_level);

    //关闭brpc的默认日志输出
    logging::LoggingSettings settings;
    settings.logging_dest = logging::LoggingDestination::LOG_TO_NONE;
    logging::InitLogging(settings);
    
    ChatSystem::UserServerBuilder userServerBuilder;
    userServerBuilder.make_dms_object(FLAGS_dms_key_id, FLAGS_dms_key_secret);
    userServerBuilder.make_es_object({FLAGS_es_host});
    userServerBuilder.make_mysql_object(FLAGS_mysql_user, FLAGS_mysql_password, FLAGS_mysql_host, 
        FLAGS_mysql_db, 
        FLAGS_mysql_cset, 
        FLAGS_mysql_port, 
        FLAGS_mysql_pool_count);
    userServerBuilder.make_redis_object(FLAGS_redis_host, FLAGS_redis_port, FLAGS_redis_db, FLAGS_redis_keep_alive);
    userServerBuilder.make_discovery_object(FLAGS_registry_host, FLAGS_base_service, FLAGS_file_service);
    userServerBuilder.make_rpc_server(FLAGS_listen_port, FLAGS_idle_timeout, FLAGS_rpc_threads);
    userServerBuilder.make_registry_object(FLAGS_registry_host, 
            FLAGS_base_service + FLAGS_instance_name, 
            FLAGS_access_host);
    auto server = userServerBuilder.build();
    server->start();
    return 0;
}

